﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Csla;
using lite;
using Csla.Validation;
using Csla.Data;
using System.Data.SqlClient;
using ZX.DAL;
using OpenExpressApp.ORM;
using ZX.EHR.Library;
using System.ComponentModel;

namespace ZX.TR.Library
{
    /// <summary>
    /// 
    /// </summary>
    [Serializable]
    [Table(Name = "V_CourseSum")]
    [ZX.DBModule.Table("V_CourseSum", "TrActivityCourseID")]
    public class V_CourseSum : ZX.DBModule.BaseEntity
    {
        #region Business Methods 业务方法

        /// <summary>
        /// ID
        /// </summary>
        private static PropertyInfo<Guid> TrActivityCourseIDProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<Guid>("TrActivityCourseID"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid TrActivityCourseID
        {
            get { return GetProperty(TrActivityCourseIDProperty); }
            set { SetProperty(TrActivityCourseIDProperty, value); }
        }
        /// <summary>
        /// 计划人数
        /// </summary>
        private static PropertyInfo<string> PlanNumProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<string>("PlanNum"));
        [Column]
        public string PlanNum
        {
            get { return GetProperty(PlanNumProperty); }
            set { SetProperty(PlanNumProperty, value); }
        }
        /// <summary>
        /// 实到人数
        /// </summary>
        private static PropertyInfo<string> ResultNumProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<string>("ResultNum"));
        [Column]
        public string ResultNum
        {
            get { return GetProperty(ResultNumProperty); }
            set { SetProperty(ResultNumProperty, value); }
        }

        /// <summary>
        /// 课程ID
        /// </summary>
        private static PropertyInfo<Guid> TrCourseIDProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<Guid>("TrCourseID"));
        [Column]
        public Guid TrCourseID
        {
            get { return GetProperty(TrCourseIDProperty); }
            set { SetProperty(TrCourseIDProperty, value); }
        }
        /// <summary>
        /// 计划开始时间
        /// </summary>
        private static PropertyInfo<DateTime> PlanStartTimeProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<DateTime>("PlanStartTime"));
        [Column]
        public DateTime PlanStartTime
        {
            get { return GetProperty(PlanStartTimeProperty); }
            set { SetProperty(PlanStartTimeProperty, value); }
        }
        /// <summary>
        /// 实际开始时间
        /// </summary>
        private static PropertyInfo<DateTime> InfactStartTimeProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<DateTime>("InfactStartTime"));
        [Column]
        public DateTime InfactStartTime
        {
            get { return GetProperty(InfactStartTimeProperty); }
            set { SetProperty(InfactStartTimeProperty, value); }
        }
        /// <summary>
        /// 实际结束时间
        /// </summary>
        private static PropertyInfo<DateTime> InfactEndTimeProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<DateTime>("InfactEndTime"));
        [Column]
        public DateTime InfactEndTime
        {
            get { return GetProperty(InfactEndTimeProperty); }
            set { SetProperty(InfactEndTimeProperty, value); }
        }
        /// <summary>
        /// 计划结束时间
        /// </summary>
        private static PropertyInfo<DateTime> PlanEndTimeProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<DateTime>("PlanEndTime"));
        [Column]
        public DateTime PlanEndTime
        {
            get { return GetProperty(PlanEndTimeProperty); }
            set { SetProperty(PlanEndTimeProperty, value); }
        }
        /// <summary>
        /// 计划名称
        /// </summary>
        private static PropertyInfo<string> ACNameProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<string>("ActivityCourseName"));
        [Column]
        public string ActivityCourseName
        {
            get { return GetProperty(ACNameProperty); }
            set { SetProperty(ACNameProperty, value); }
        }
        /// <summary>
        /// 计划总结
        /// </summary>
        private static PropertyInfo<string> ACSumProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<string>("CourseSumary"));
        [Column]
        public string CourseSumary
        {
            get { return GetProperty(ACSumProperty); }
            set { SetProperty(ACSumProperty, value); }
        }
        /// <summary>
        /// 城市
        /// </summary>
        private static PropertyInfo<string> CityProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<string>("City"));
        [Column]
        public string City
        {
            get { return GetProperty(CityProperty); }
            set { SetProperty(CityProperty, value); }
        }


        /// <summary>
        /// 课程内容
        /// </summary>
        private static PropertyInfo<string> CourseContentProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<string>("CourseContent"));
        [Column]
        public string CourseContent
        {
            get { return GetProperty(CourseContentProperty); }
            set { SetProperty(CourseContentProperty, value); }
        }
        /// <summary>
        /// 课前准备
        /// </summary>
        private static PropertyInfo<string> CoursePrepareProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<string>("CoursePrepare"));
        [Column]
        public string CoursePrepare
        {
            get { return GetProperty(CoursePrepareProperty); }
            set { SetProperty(CoursePrepareProperty, value); }
        }
        /// <summary>
        /// 活动名称
        /// </summary>
        private static PropertyInfo<string> ActivityNameProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<string>("ActivityName"));
        [Column]
        public string ActivityName
        {
            get { return GetProperty(ActivityNameProperty); }
            set { SetProperty(ActivityNameProperty, value); }
        }
        /// <summary>
        /// 学员
        /// </summary>
        private static PropertyInfo<string> StudentNameProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<string>("StudentName"));
        [Column]
        public string StudentName
        {
            get { return GetProperty(StudentNameProperty); }
            set { SetProperty(StudentNameProperty, value); }
        }
        /// <summary>
        /// 课程名称
        /// </summary>
        private static PropertyInfo<string> CourseNameProperty = RegisterProperty(typeof(V_CourseSum), new PropertyInfo<string>("CourseName"));
        [Column]
        public string CourseName
        {
            get { return GetProperty(CourseNameProperty); }
            set { SetProperty(CourseNameProperty, value); }
        }
        #endregion
        #region Validation Rules 验证规则
        //将验证规则与业务对象的属性联系在一起
        protected override void AddBusinessRules()
        {
            //AddRule的第一个参数是委托变量，也就是说是方法的变量
            ValidationRules.AddRule(CommonRules.StringRequired, "ActivityCourseName");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("ActivityCourseName", 50));
            ValidationRules.AddRule(CommonRules.StringRequired, "CourseContent");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("CourseContent", 500));
            ValidationRules.AddRule(CommonRules.StringRequired, "CoursePrepare");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("CoursePrepare", 500));
            
            //base.AddBusinessRules();
        }

        #endregion
        #region Factory Methods 工厂方法

        public V_CourseSum() { }

        public static V_CourseSum New()
        {
            return DataPortal.Create<V_CourseSum>();
        }
        public static V_CourseSum Get(Guid TrActivityCourseID)
        {
            return DataPortal.Fetch<V_CourseSum>(new SingleLazyCriteria<V_CourseSum, Guid>(TrActivityCourseID, false));
        }
        public static void Delete(Guid TrActivityCourseID)
        {
            DataPortal.Delete(TrActivityCourseID);
        }

        //public override TrActivityCourse Save()
        //{
        //return base.Save();
        //}
        #endregion

        #region Data Access 数据访问
        //由于DataPortal_create中没有对数据库的访问，所有标记了Runlocal特性，使得该方法只需在本地运行即可
        //如果代码中有访问数据库的方法，那么就不要用这个特性，使数据门户可以根据情况将此方法的运行选择在应用服务器还是本地
        [RunLocal()]
        protected override void DataPortal_Create()
        {
            //在此调用CheckRules对所有的属性进行验证规则的检查，这样检查只运行一次。
            ValidationRules.CheckRules();
        }


        //可以看到此方法没有标记任何特性
        //此方法要访问数据库所以不能标记本地，由于她没有任何数据库更新操作所以也无需事务性的保护
        //此方法调用结束后会隐含的调用MarkOld（）方法
        private void DataPortal_Fetch(Guid TrActivityCourseID)
        {
            //通过连接字符串建立SQL连接对象，Using符号代表，范围释放的意思，SqlConnection对象会在此范围后被释放掉
            using (var ctx = ConnectionManager<SqlConnection>.GetManager(ConnectionStringNames))
            {
                IDb db = DbFactory.Instance.GetDb(ctx.Connection);
                IQuery q = db.Query();
                q.Constrain("TrActivityCourseID").Equal(TrActivityCourseID);
                var data = db.Select<V_CourseSum>(q)[0];
                LoadProperty(TrActivityCourseIDProperty, data.TrActivityCourseID);
                LoadProperty(TrCourseIDProperty, data.TrCourseID);
                LoadProperty(StudentNameProperty, data.StudentName);
                LoadProperty(ACNameProperty, data.ActivityCourseName);
                LoadProperty(PlanStartTimeProperty, data.PlanStartTime);
                LoadProperty(PlanEndTimeProperty, data.PlanEndTime);
                LoadProperty(CourseContentProperty, data.CourseContent);
                LoadProperty(CoursePrepareProperty, data.CoursePrepare);
                LoadProperty(ActivityNameProperty, data.ActivityName);
                LoadProperty(CourseNameProperty, data.CourseName);
                LoadProperty(PlanNumProperty, data.PlanNum);
                LoadProperty(ResultNumProperty, data.ResultNum);
                LoadProperty(InfactStartTimeProperty, data.InfactStartTime);
                LoadProperty(ACSumProperty, data.CourseSumary);
                LoadProperty(InfactEndTimeProperty, data.InfactEndTime);
                //LoadProperty(ShareUsernameProperty, data.ShareUsername);
                //LoadProperty(ReviewUsernameProperty, data.ReviewUsername);
            }
        }

        [Transactional(TransactionalTypes.TransactionScope)]
        protected override void DataPortal_DeleteSelf()
        {
            //依然是调用下面的方法删除的，只是他此时可以获得自己的Id
            DataPortal_Delete(TrActivityCourseIDProperty);
        }
        #endregion
    }
}
